草庐IT

shell - 将 .csv 文件导入 sqlite3 db 表

全部标签

Ruby 在复制文件时显示进度

我希望能够在使用Ruby复制文件时显示文件复制操作的进度(当前使用FileUtils.cp)我已经尝试将verbose选项设置为是的,但这似乎只是向我展示了发出的复制命令。我现在正在从命令行运行这个脚本,所以理想情况下我希望能够像SCP在复制文件时那样呈现一些东西,但只要我能,我就不太在意呈现查看进度。 最佳答案 因为我没有足够的代表来编辑答案,所以这是我基于pisswillis答案的版本,我找到了progressbargem我也在我的例子中使用。我已经对此进行了测试,到目前为止它工作正常,但它可以做一些清理工作:require'r

ruby - 使用 Ruby CSV header 转换器

假设我有以下类(class):classBuyer以及CSV文件中的以下内容:FirstName,LastNameJohn,DoeJane,Doe我想将CSV的内容保存到数据库中。我在Rake文件中有以下内容:namespace:migrationdodesc"MigrateCSVdata"task:import,[:model,:file_path]=>:environmentdo|t,args|require'csv'model=args.model.constantizepath=args.file_pathCSV.foreach(path,:headers=>true,:con

ruby - 如何让 fish shell 默认使用 rvm ruby

我在MacOSX10.9.1上使用fishshell2.10。我想在我的终端中使用我使用RVM作为默认安装的Ruby,但我似乎无法完成这项工作。我已经尝试过rvmuse2.1.0--default但在打开一个新终端时我仍然得到以下信息:>whichruby/usr/bin/ruby运行rvm命令会加载ruby​​:>whichruby/usr/bin/ruby>rvm[...]>whichruby/Users/alex/.rvm/rubies/ruby-2.1.0/bin/ruby但每次我打开一个新终端时都必须这样做很烦人。 最佳答案

ruby-on-rails - 将时间戳添加到 db Rails 5+ 中的现有表

正在尝试将时间戳添加到现有表中。根据Apidocumenationadd_timestamps这是我的迁移代码:defchangeadd_timestamps(:products,null:false)end获取错误:*--add_timestamps(:products,{:null=>false})railsaborted!StandardError:Anerrorhasoccurred,thisandalllatermigrationscanceled:SQLite3::SQLException:CannotaddaNOTNULLcolumnwithdefaultvalueNUL

ruby - 从 Jekyll 插件返回目录中的文件列表?

我不知道如何在jekyll插件中创建过滤器或标签,以便我可以返回目录并循环遍历其内容。我找到了这些:http://pastebin.com/LRfMVN5Yhttp://snippets.dzone.com/posts/show/302到目前为止我有:moduleJekyllclassFilesTag我可以成功地将图像列表作为字符串返回并打印:{%filestest_string%}但对于我来说,无论我如何从Dir.glob返回数组/散列,我都无法遍历数组。我只想能够做到:{%forimageinfiles%}image{%endfor%}我将需要能够为我将在网站上使用的各种集合不断返

ruby-on-rails - Rails/Ruby/Postgres - LoadError 无法加载此类文件 -- pg_ext

我正在尝试使用下面的railsController调用一个Ruby脚本(它连接到一个postgres数据库),但是它似乎在加载一个PGgem文件时遇到问题。我已经将我的require语句设置为需要'pg'并尝试了绝对路径(需要/usr/local/rvm/gems/ruby-1.9.3-p194@railsTest/gems/pg-0.14.0/库/pg/)。文件“pg_ext”实际上存在于目录中。此外,我可以毫无问题地独立运行ruby​​脚本(dbrubyscript.rb),但是当将rails添加到这个等式时,它会出现cannotloadsuchfile--pg_ext错误。这里的

ruby - 使用 Sinatra 提供静态文件

我有一个仅使用HTML、CSS和JavaScript的页面网站。我想将应用程序部署到Heroku,但我找不到执行此操作的方法。我现在正在尝试使应用程序与Sinatra一起工作。.|--application.css|--application.js|--index.html|--jquery.js`--myapp.rb下面是myapp.rb的内容。require'rubygems'require'sinatra'get"/"do#WhatshouldIwriteheretopointtothe`index.html`end 最佳答案

ruby-on-rails - 为什么 `rake db:drop` 失败时退出状态为 0,并且不引发错误?

我惊讶地发现,当rakedb:drop(假设是Rails的其他内置raketasks)失败时,bash状态代码为0。$rakedb:dropcouldnotconnecttoserver:ConnectionrefusedIstheserverrunningonhost"localhost"(::1)andacceptingTCP/IPconnectionsonport5432?...$echo$?0也许更令人惊讶的是,当从Rails中调用任务时,它甚至不会引发错误。2.3.0:001>begin2.3.0:002>Rake::Task["db:drop"].invoke2.3.0:0

ruby-on-rails - Carreirwave - 如何直接从保存的文件名创建版本名称

我正在为已上传到我的应用程序的文件创建缩略图。图像名称中有一个时间戳代码。当我运行recreate_versions时,生成的缩略图也有时间戳,但它使用当前时间戳,这使得缩略图名称与原始文件名不同。所以我认为解决方法是为缩略图自定义文件名。基本上有'thumb_'+'原始文件名'。version:thumbdoprocess:resize_to_limit=>[110,nil]deffull_filename(for_file=model.image_value.file)'thumb_'+File.basename(model.image_value.path).to_sendend

读取时出现 Ruby CSV UTF8 编码错误

这是我在做的:csv=CSV.open(file_name,"r")我用它来测试:line=csv.shiftwhilenotline.nil?putslineline=csv.shiftend我遇到了这个:ArgumentError:invalidbytesequenceinUTF-8我读了answerhere这就是我尝试过的csv=CSV.open(file_name,"r",encoding:"windows-1251:utf-8")我遇到了以下错误:Encoding::UndefinedConversionError:"\x98"toUTF-8inconversionfromW